﻿/************************************************************************
* Copyright (c) 2018 All Rights Reserved.
*命名空间：Common.Standard
*文件名： MapHelper
*创建人： kingling
*创建时间：2018/7/28 13:04:24
*描述
*=======================================================================
*修改标记
*修改时间：2018/7/28 13:04:24
*修改人：kingling
*描述：
************************************************************************/

using System;
using System.Collections.Generic;
using System.Text;

namespace Common.Standard
{
    public class MapHelper
    {
        /// <summary>
        /// 获取两个火星坐标之间的距离
        /// </summary>
        /// <param name="lat1">第一个坐标的X</param>
        /// <param name="lng1">第一个坐标的Y</param>
        /// <param name="lat2">第二个坐标的X</param>
        /// <param name="lng2">第二个坐标的Y</param>
        /// <returns>两个坐标之间的距离</returns>
        public static double GetDistanceWithMars(decimal lat1, decimal lng1, decimal lat2, decimal lng2)
        {
            try
            {
                var b = Math.PI / 180;
                var c = Math.Sin(((double)lat2 - (double)lat1) * b / 2);
                var d = Math.Sin(((double)lng2 - (double)lng1) * b / 2);
                var a = c * c + d * d * Math.Cos((double)lat1 * b) * Math.Cos((double)lat2 * b);
                return 12756274 * Math.Atan2(Math.Sqrt(a), Math.Sqrt(1 - a));
            }
            catch
            {

                return 0;
            }
        }
    }
}
